/* =====================================================
   Bethy Coiff – Unified & Optimised CSS (v2025-06-07 patch-b)
   Changements suite aux retours :
   1. Restauration de l’animation "ciseaux → flèche" (buttonn)
   2. Recentrage des sections « Nos Prestations », « Où nous trouver » & « Horaires »
   3. Grille services : 2 colonnes sur mobile (< 600 px) pour un alignement façon « dé à 6 »
   ===================================================== */

/* ---------------- Core tokens ---------------- */
:root{--c-primary:#a83b3b;--c-primary-dark:#8e2c2c;--c-secondary:#d9b6a3;--c-bg-light:#faf3f0;--c-bg-card:#fff;--c-text:#333;--radius:10px;--shadow-s:0 2px 5px rgba(0 0 0/.1);--shadow-m:0 4px 6px rgba(0 0 0/.1);--shadow-l:0 4px 15px rgba(0 0 0/.1);--transition:.3s ease;}
*{box-sizing:border-box;margin:0;padding:0;}
body{display:flex;flex-direction:column;min-height:100vh;font-family:Georgia,serif;background:var(--c-bg-light);color:var(--c-text);}

h1,h2,h3,h4,h5,h6,.page-title,#servicessss h2,#gallery h2,#location h2,#horaires h2{font-family:"Lora",serif;font-optical-sizing:auto;font-weight:600;}

/* ---------------- Banner ---------------- */
.banner{display:flex;align-items:center;justify-content:center;gap:20px;background:var(--c-primary);color:#fff;padding:15px 30px;position:relative;}
.logo-bethy{width:100px;position:absolute;left:30px;top:50%;transform:translateY(-50%);}
.text-content{text-align:center;}
@media(max-width:768px){.logo-bethy{width:70px;left:15px;}}
@media(max-width:600px){.banner-content{gap:14px;}.logo-bethy{margin-bottom:6px;}header .banner h1{line-height:1.15;}header .banner p{margin-top:6px;line-height:1.2;}}

/* ---------------- Navbar ---------------- */
.navbar{background:var(--c-secondary);display:flex;justify-content:center;padding:10px 0;box-shadow:var(--shadow-m);}
.navbar ul{display:flex;gap:20px;list-style:none;}
.navbar a{padding:8px 12px;border-radius:5px;font-weight:700;color:var(--c-text);text-decoration:none;transition:var(--transition);}
.navbar a:hover{background:var(--c-primary);color:#fff;}
@media(max-width:768px){.navbar ul{gap:15px;}.navbar a{padding:6px 10px;font-size:14px;}}

/* ---------------- Section wrappers ---------------- */
section{text-align:center;padding:40px 20px;}
.page-title{font:700 2.5rem "Times New Roman",serif;color:var(--c-primary);margin:20px 0;}
.servicessss-note{font-size:.9rem;color:var(--c-primary);margin:15px 0;}
#servicessss h2,#gallery h2,#location h2,#horaires h2{font:700 2.5rem "Times New Roman",serif;color:var(--c-primary);margin-bottom:20px;text-align:center;}
#servicessss p,#location p,#horaires p{text-align:center;}

/* ---------------- Service LIST (index) ---------------- */
.servicessss-list{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.servicessss-item{background:var(--c-bg-card);width:300px;padding:20px;border-radius:var(--radius);box-shadow:var(--shadow-m);text-align:left}
.servicessss-item h3{font:700 1.5rem Georgia,serif;color:var(--c-text);border-bottom:2px solid var(--c-primary);margin-bottom:10px;padding-bottom:5px}
.servicessss-item p{color:#555;margin:5px 0}
/* ---------------- Gallery ---------------- */
#gallery{background:#f4e8e4;}
.gallery{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;}
.gallery img{width:200px;border-radius:var(--radius);box-shadow:var(--shadow-m);object-fit:cover;}

/* ---------------- Contact & footer ---------------- */
#contact{background:var(--c-bg-card);}
#contact .btn{display:inline-block;margin-top:10px;padding:10px 20px;background:var(--c-primary);color:#fff;border-radius:5px;font-weight:700;transition:var(--transition);}
#contact .btn:hover{background:var(--c-primary-dark);}
footer{background:#333;color:#fff;text-align:center;padding:10px 0;margin-top:auto;width:100%;}

/* ===================== Services PAGE ===================== */

/* Encadré titre + note */
.services-header{max-width:900px;margin:30px auto 32px;padding:28px 24px;background-color:#EFE1D7;border-radius:18px;text-align:center;box-shadow:var(--shadow-s);}
.services-header .page-title{margin:0 0 12px;color:var(--c-primary-dark);font-family:"Lora",serif;font-weight:700;}
.services-header .service-note{margin:0;font-size:.95rem;color:#6a3f32;line-height:1.5;}

/* ========== Carte "Nombre de personnes" ========== */
.people-count-card{max-width:520px;margin:18px auto 34px;padding:18px 22px;background-color:#EFE1D7;border-radius:20px;text-align:center;box-shadow:0 6px 18px rgba(0,0,0,0.05);}
.people-count-card h3{margin:0 0 12px;font-family:"Lora",serif;font-weight:700;color:var(--c-primary-dark);}
#people-count{font-weight:700;}

/* Stepper */
.people-count-card .people-stepper{display:inline-flex;align-items:center;justify-content:center;gap:10px;margin:0 auto;padding:8px 12px;background:rgba(255,255,255,0.55);border:1px solid rgba(0,0,0,0.06);border-radius:999px;}
.people-count-card .stepper-btn{width:42px;height:42px;padding:0;border:none;border-radius:999px;background:var(--c-primary);color:#fff;display:grid;place-items:center;font-size:22px;line-height:1;cursor:pointer;transition:background-color .2s ease,transform .1s ease;}
.people-count-card .stepper-btn:hover{background:var(--c-primary-dark);transform:translateY(-1px);}
.people-count-card .stepper-btn:active{transform:translateY(0) scale(0.98);}

/* Input nombre */
.people-count-card #numPeople{width:64px;height:38px;padding:0 10px;font-size:16px;border:1px solid rgba(0,0,0,0.18);border-radius:999px;text-align:center;background:#fff;outline:none;}
.people-count-card #numPeople:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(196,106,74,0.18);}
.people-count-card #numPeople::-webkit-outer-spin-button,.people-count-card #numPeople::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}

/* ========== Formulaire par personne ========== */
.person-service{background:var(--c-bg-card);padding:18px;margin-bottom:15px;border-radius:var(--radius);box-shadow:var(--shadow-s);display:flex;flex-direction:column;gap:10px;}
.person-service h4{font-size:18px;margin-bottom:6px;color:var(--c-text);text-align:center;}
.person-service label{display:block;margin:10px 0 6px;font-weight:700;color:var(--c-text);}

/* Selects (desktop + base) */
.person-service .hair-length-select,.person-service .service-type-select{width:100%;max-width:360px;padding:12px 14px;border-radius:14px;border:1px solid rgba(0,0,0,0.14);background:#fff;box-shadow:0 6px 16px rgba(0,0,0,0.04);font-size:15px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,transform .12s ease;}
.person-service .hair-length-select:focus,.person-service .service-type-select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(168,59,59,0.18),0 10px 22px rgba(0,0,0,0.05);transform:translateY(-1px);}

/* Desktop : alignement propre */
@media(min-width:900px){.person-service{align-items:flex-start;}.person-service label{text-align:left;}}

/* ========== Mobile ========== */
@media(max-width:600px){
  .services-header{margin:18px 14px 18px;padding:18px 16px;border-radius:18px;box-shadow:0 4px 14px rgba(0,0,0,0.03);}
  .services-header .page-title{font-size:2rem;}
  .services-header .service-note{font-size:.92rem;}
  .people-count-card{margin:14px 14px 24px;padding:16px 18px;}
  .person-service{padding:16px;gap:8px;}
  .person-service label{margin:10px 0 6px;font-size:.95rem;}
  .person-service .hair-length-select,.person-service .service-type-select{max-width:100%;padding:14px 44px 14px 14px;border-radius:16px;font-size:16px;box-shadow:0 8px 18px rgba(0,0,0,0.06);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%238e2c2c' d='M7 10l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:18px;}
}

/* ===================== Desktop layout : selects côte à côte + centrés ===================== */
@media(min-width:900px){
  .person-service{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"title title""label1 label2""select1 select2""cards cards";column-gap:28px;row-gap:10px;align-items:start;justify-items:center;padding:26px 28px;}
  .person-service h4{grid-area:title;text-align:center;margin-bottom:6px;}
  .person-service label:nth-of-type(1){grid-area:label1;width:100%;max-width:420px;text-align:left;justify-self:center;}
  .person-service label:nth-of-type(2){grid-area:label2;width:100%;max-width:420px;text-align:left;justify-self:center;}
  .person-service .hair-length-select{grid-area:select1;width:100%;max-width:420px;justify-self:center;}
  .person-service .service-type-select{grid-area:select2;width:100%;max-width:420px;justify-self:center;}
  .person-service .services-list{grid-area:cards;width:100%;margin-top:14px;justify-items:center;}
}

.services-list{display:grid;grid-template-columns:repeat(auto-fit,180px);gap:18px;justify-content:center;justify-items:center;align-items:start;margin-top:18px;grid-auto-rows:minmax(160px,auto);}
@media(max-width:760px){.services-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}}

/* ===== Service cards : moins “vide”, plus premium ===== */
.service-card{
  background:linear-gradient(180deg,#f3e7e3 0%,#ead7d1 100%);
  border:1.8px solid rgba(0,0,0,0.16);
  border-radius:14px;
  box-shadow:0 6px 16px rgba(0,0,0,0.06);
  padding:14px 12px;
  width:180px;
  min-height:120px;

  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:8px;

  text-align:center;
  cursor:pointer;
  transition:transform .18s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease;
}

@media(max-width:760px){
  .service-card{
    width:100%;
    min-height:110px;
    padding:14px 10px;
  }
}

.service-card:hover{
  border-color:rgba(168,59,59,0.55);
  box-shadow:0 10px 22px rgba(0,0,0,0.08);
  transform:translateY(-2px);
}

.service-card.selected{
  background:linear-gradient(180deg,#efd6cf 0%,#e3bdb5 120%);
  border-color:var(--c-primary);
  box-shadow:0 12px 26px rgba(168,59,59,0.16);
}

.service-card-title{
  margin:0;
  font-size:1rem;
  line-height:1.15;
  color:var(--c-text);
  font-weight:700;
}

.service-card-price{
  margin:0;
  font-size:.95rem;
  font-weight:800;
  color:var(--c-primary-dark);
}

/* (Optionnel mais propre) : quand selected sur desktop, garde une taille raisonnable */
@media(min-width:761px){
  .service-card.selected{
    grid-row:span 2;
    min-height:260px; /* au lieu de 330, ça fait moins “trop grand” */
  }
}


.addon-group{display:none;width:100%;margin-top:10px;padding:12px;border-radius:14px;background:rgba(239,225,215,.65);border:1px solid rgba(0,0,0,.08);gap:10px;}
.service-card.selected .addon-group{display:flex;flex-direction:column;}

.addon-group label{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.10);background:rgba(255,255,255,.90);cursor:pointer;user-select:none;font-weight:700;font-size:.95rem;transition:transform .12s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;word-break:normal;overflow-wrap:normal;}
.addon-group label:hover{transform:translateY(-1px);border-color:rgba(168,59,59,.35);box-shadow:0 10px 20px rgba(0,0,0,.06);}
.addon-group label:has(.addon-checkbox:checked){background:rgba(168,59,59,.10);border-color:rgba(168,59,59,.45);}

.addon-group label span{display:flex;flex-direction:column;align-items:center;line-height:1.15;white-space:normal;word-break:normal;overflow-wrap:normal;hyphens:none;}

.addon-checkbox{appearance:none;-webkit-appearance:none;width:22px;height:22px;border-radius:7px;border:2px solid rgba(168,59,59,.40);background:#fff;display:grid;place-items:center;margin-bottom:2px;flex:0 0 auto;}
.addon-checkbox:checked{background:var(--c-primary);border-color:var(--c-primary);}
.addon-checkbox:checked::after{content:"✓";color:#fff;font-size:14px;line-height:1;font-weight:900;}



/* ----- Recap bloc... (inchangé) ----- */
/* ===== Récapitulatif flottant ===== */
#recap{
  position:fixed;
  bottom:20px;
  right:20px;

  width:320px;
  max-width:calc(100vw - 40px);

  background:var(--c-bg-card);
  border:1px solid #ccc;
  border-radius:16px;
  box-shadow:0 10px 30px rgba(0,0,0,0.15);

  padding:20px;
  text-align:center;

  z-index:1000; /* au-dessus du contenu */
}

@media(max-width:600px){
  #recap{
    bottom:0;
    right:0;
    left:0;

    width:100%;
    max-width:100%;
    border-radius:16px 16px 0 0;

    padding:10px 14px;
    box-shadow:0 -6px 20px rgba(0,0,0,0.15);

    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
  }

  #recap h3{
    display:none; /* on vire "Récapitulatif" */
  }

  #recap ul{
    display:none; /* on masque le détail */
  }

  #recap p{
    margin:0;
    font-size:1rem;
    font-weight:700;
    white-space:nowrap;
  }

  #proposeAppointment{
    padding:10px 14px;
    font-size:.95rem;
    border-radius:10px;
    flex-shrink:0;
  }
}

#proposeAppointment{margin-top:20px;padding:10px 20px;background:var(--c-primary);color:#fff;border:none;border-radius:5px;cursor:pointer;transition:var(--transition);}
#proposeAppointment:hover{background:var(--c-primary-dark);}

/* ----- Finaliser page recap (inchangé) ----- */
#finalibody{background:#fef7f4;font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;color:var(--c-text);}
#finali{background:var(--c-primary);color:#fff;text-align:center;box-shadow:var(--shadow-s);}
#finalih1{font-size:2.5rem;font-weight:700;margin:0;}
#recapServices{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;max-width:1200px;margin:40px auto;padding:20px;background:var(--c-bg-card);border-radius:var(--radius);box-shadow:var(--shadow-l);}
.person-block{background:#fefaf7;padding:20px;width:45%;border-radius:var(--radius);border-left:5px solid var(--c-primary);box-shadow:0 2px 8px rgba(0 0 0/.05);}
.person-block h3{color:var(--c-primary);margin-bottom:10px;font-size:1.4rem;}
@media(max-width:768px){.person-block{width:100%;}}
.total-price{font-weight:700;font-size:1.2rem;color:var(--c-primary);margin-top:10px;}

/* ----- Contact form / inputs (inchangé) ----- */
#contactInfo{max-width:1200px;margin:40px auto;padding:30px;background:var(--c-bg-card);border-radius:calc(var(--radius)+5px);box-shadow:var(--shadow-l);display:flex;flex-direction:column;gap:20px;}
.flex-container{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;}
.flex-item{flex:1;min-width:48%;max-width:48%;display:flex;flex-direction:column;gap:10px;}
@media(max-width:768px){.flex-container{flex-direction:column;}.flex-item{min-width:100%;max-width:100%;}}
.input-style,.phone-input{width:100%;padding:10px;border:2px solid var(--c-primary);border-radius:25px;margin-bottom:15px;}
button,.custom-file-upload,#contactInfo button{background:var(--c-primary);color:#fff;border:none;padding:10px 20px;font-size:1rem;border-radius:5px;cursor:pointer;transition:var(--transition);}
button:hover,.custom-file-upload:hover,#contactInfo button:hover{background:var(--c-primary-dark);}

/* ----- Circular "Retour" button (scissors → arrow) ----- */
.buttonn{cursor:pointer;border:none;background:#B23B3B;color:#fff;width:100px;height:100px;border-radius:50%;display:grid;place-content:center;font-weight:600;overflow:hidden;position:relative;transition:background .3s,transform .2s;}
.buttonn:hover{background:#8A2B2B;transform:scale(1.05);}
.buttonn__circle{position:relative;width:40px;height:40px;background:#fff;color:var(--c-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;}
.buttonn__icon{transition:transform .3s ease-in-out,color .2s;}
.buttonn__icon--copy{position:absolute;transform:translate(-150%,150%);color:var(--c-primary);}
.buttonn:hover .buttonn__icon:first-child{transform:translate(150%,-150%);}
.buttonn:hover .buttonn__icon--copy{transform:translate(0);}
.buttonn__text{position:absolute;inset:0;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;animation:text-rotation 15s linear infinite;color:#fff;}
.buttonn__text span{position:absolute;inset:7px;transform:rotate(calc(19deg * var(--index)));}
@keyframes text-rotation{to{transform:rotate(360deg);}}

/* ----- Carousel / zoom (inchangé) ----- */
.carousel-container{position:relative;max-width:800px;margin:auto;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-m);}
.carousel{display:flex;gap:10px;overflow-x:auto;scroll-behavior:smooth;cursor:grab;text-align:left;}
.carousel::-webkit-scrollbar{display:none;}
.carousel img{width:25%;border-radius:var(--radius);object-fit:cover;flex-shrink:0;}
.zoom-overlay{position:fixed;inset:0;background:rgba(0 0 0/.8);display:flex;align-items:center;justify-content:center;visibility:hidden;opacity:0;transition:var(--transition);z-index:1000;}
.zoom-overlay.visible{visibility:visible;opacity:1;}
.zoom-overlay img{max-width:90%;max-height:90%;border-radius:var(--radius);cursor:pointer;}

/* ========== SLOT-TABLE RÉSERVATION (vFinal Planity Desktop/Mobile) ========== */
.slot-wrapper{background:var(--c-bg-card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow-s);max-width:100%;overflow:hidden;margin-bottom:25px;}
.slot-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:16px;}
.slot-nav button{background:none;border:none;font-size:2rem;color:var(--c-primary);cursor:pointer;transition:.2s;font-weight:700;padding:2px 10px;}
.slot-nav button:disabled{opacity:.3;cursor:not-allowed;}
#weekLabel{font-size:1.15rem;font-weight:700;color:var(--c-primary);flex:1;text-align:center;}
.slot-table{display:grid;grid-auto-flow:column;gap:28px;justify-content:center;overflow-x:auto;padding-bottom:10px;width:100%;}
.slot-col{background:#f9f3f2;border-radius:var(--radius);padding:14px 0 18px 0;min-width:240px;max-width:290px;border:1.5px solid #f3d9d4;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 2px 9px #e4b7b340;transition:box-shadow .2s;}
.slot-header{font-weight:700;text-align:center;color:var(--c-primary);font-size:1.08rem;margin-bottom:12px;background:transparent;cursor:pointer;user-select:none;padding-bottom:2px;border-radius:9px 9px 0 0;}
.slot-grid{display:flex;flex-direction:column;gap:10px;width:90%;margin:0 auto;}
.slot-row{display:flex;gap:10px;justify-content:center;}
.slot-btn{flex:1 1 0;background:#fff;border:2px solid #e7d7d4;border-radius:12px;color:var(--c-primary);font-weight:600;font-size:1rem;padding:13px 0;margin:0;transition:background .2s,color .2s,border-color .2s;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.03);min-width:86px;max-width:125px;}
.slot-btn.selected{background:var(--c-primary);color:#fff;border-color:var(--c-primary);}
.slot-btn-empty{visibility:hidden;}
@media(max-width:700px){
  .slot-table{display:flex;flex-direction:column;gap:18px;overflow-x:unset;padding-bottom:0;}
  .slot-col{max-width:96vw;min-width:0;width:100%;padding:0 0 10px 0;border:none;border-bottom:1.5px solid #e7d4ce;border-radius:var(--radius) var(--radius) 0 0;background:#f7eeeb;box-shadow:0 2px 8px #e4b7b326;margin:0 auto;}
  .slot-header{font-size:1.15rem;background:#f2e7e3;color:var(--c-primary);border-radius:10px 10px 0 0;padding:13px 0;margin-bottom:0;text-align:center;width:100%;}
  .slot-col .slot-grid{display:none;}
  .slot-col.open .slot-grid{display:flex;}
  .slot-col:not(.open){box-shadow:none;}
  .slot-row{justify-content:center;gap:10px;}
  .slot-btn{min-width:39vw;max-width:44vw;font-size:1rem;padding:13px 0;margin:0;}
}

/* ---------------- Header Bethy (nouveau style) ---------------- */
.header-bethy{background:linear-gradient(135deg,#a83b3b 65%,#e48b8b 100%);padding:36px 0 26px 0;border-bottom-left-radius:32px;border-bottom-right-radius:32px;box-shadow:0 8px 32px #a83b3b15;position:relative;text-align:center;}
.header-top{display:flex;align-items:center;justify-content:space-between;max-width:980px;margin:0 auto 14px auto;padding:0 28px;}
.header-logo img{height:56px;width:56px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #a83b3b10;}
.header-link a{color:#fff;font-weight:600;text-decoration:none;background:rgba(255,255,255,0.13);padding:8px 18px 8px 12px;border-radius:20px;font-size:1.05rem;display:flex;align-items:center;gap:8px;transition:background .2s;}
.header-link a:hover{background:rgba(255,255,255,0.32);}
.header-link i{font-size:1.3em;}
.header-main h1{font-size:2.4rem;font-weight:bold;margin-bottom:8px;color:#fff;letter-spacing:.02em;line-height:1.2;text-shadow:0 2px 6px #a83b3b50;}
.header-brand{display:inline-block;color:#fff;background:#a83b3b99;padding:6px 24px;font-weight:600;font-size:1.06rem;border-radius:18px;margin-top:7px;letter-spacing:.04em;box-shadow:0 2px 12px #a83b3b10;text-decoration:none;transition:background .18s;}
.header-brand:hover{background:#a83b3bcc;}
@media(max-width:600px){
  .header-bethy{padding:22px 0 16px 0;border-radius:0 0 18px 18px;}
  .header-top{flex-direction:row;justify-content:space-between;padding:0 10px;}
  .header-logo img{height:36px;width:36px;}
  .header-main h1{font-size:1.3rem;}
  .header-brand{font-size:.95rem;padding:6px 18px;}
}
/* =========================================================
   Bethy Coiffure — CSS unique (site + page Boutique)
   Objectif : rendu premium, lisible, moins de “vide”
   ========================================================= */

/* =========================
   1) RESET / BASE
   ========================= */
*{ box-sizing:border-box; }
html, body{ margin:0; padding:0; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; }

/* =========================
   2) TOKENS / THEME
   ========================= */
:root{
  --c-primary:#a83b3b;
  --c-primary-dark:#8e2c2c;
  --c-soft:#d9b6a3;

  --c-bg:#fbf4f1;
  --c-card:#ffffff;
  --c-ink:#2a2322;
  --c-muted:#6b5d5a;

  --radius:18px;
  --radius-s:12px;

  --shadow-s:0 8px 18px rgba(0,0,0,.08);
  --shadow-m:0 16px 30px rgba(0,0,0,.10);

  --line:rgba(0,0,0,.08);
}

/* =========================
   3) TYPO
   ========================= */
body{
  font-family: "Georgia", serif;
  color:var(--c-ink);
  background:var(--c-bg);
  line-height:1.45;
}

/* Titres (style “boutique”) */
h1,h2,h3,h4{
  margin:0 0 10px 0;
  font-weight:700;
  color:var(--c-primary-dark);
  letter-spacing:.3px;
}

p{ margin:0 0 12px 0; color:var(--c-ink); }
small{ color:var(--c-muted); }

/* =========================
   4) HEADER / NAV
   ========================= */
header{ width:100%; }

.banner{
  background:var(--c-primary);
  padding:18px 16px;
}

.banner-content{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:14px;
}

.logo-bethy{
  width:64px;
  height:auto;
}

.text-content h1{
  color:#fff;
  font-size:36px;
  line-height:1.05;
}

.text-content p{
  margin:6px 0 0 0;
  color:#fff;
  opacity:.95;
}

.navbar{
  background:var(--c-soft);
  box-shadow:0 4px 10px rgba(0,0,0,.08);
}

.navbar ul{
  list-style:none;
  margin:0;
  padding:10px 12px;
  display:flex;
  justify-content:center;
  gap:22px;
  flex-wrap:wrap;
}

.navbar a{
  display:inline-block;
  padding:10px 14px;
  border-radius:999px;
  font-weight:700;
  color:#1f1a19;
}

.navbar a:hover{
  background:rgba(255,255,255,.35);
}

.navbar a[aria-current="page"]{
  background:rgba(255,255,255,.55);
  outline:1px solid rgba(0,0,0,.12);
}


/* =========================
   6) LAYOUT PAGE BOUTIQUE
   ========================= */
.boutique-wrap{
  max-width:1200px;
  margin:24px auto 60px auto;
  padding:0 14px;
}

/* “matière” en fond des sections : réduit l’impression de vide */
.boutique-wrap > section{
  position:relative;
  margin:18px 0;
}

/* Carte générique premium */
.luxe-card,
.catalogue-card,
.gammes-card,
.luxe-section,
.how-card{
  background:var(--c-card);
  border-radius:var(--radius);
  box-shadow:var(--shadow-s);
  border:1px solid rgba(0,0,0,.04);
}

/* petite bordure intérieure douce (effet luxe) */
.luxe-card,
.catalogue-card,
.gammes-card,
.luxe-section,
.how-card{
  background-image: radial-gradient(circle at top left, rgba(168,59,59,.06), transparent 45%);
}

/* =========================
   7) HERO (screen 2 amélioré)
   ========================= */
.luxe-hero{
  padding:18px;
}

.luxe-hero-inner{
  display:grid;
  grid-template-columns: 1.35fr .85fr;
  gap:16px;
  align-items:stretch;
}

.luxe-hero-left{
  padding:18px 18px 16px 18px;
  border-radius:var(--radius);
  background:
    radial-gradient(circle at 20% 10%, rgba(168,59,59,.08), transparent 45%),
    radial-gradient(circle at 80% 30%, rgba(217,182,163,.18), transparent 55%),
    #fff;
  border:1px solid rgba(0,0,0,.04);
}

.boutique-title{
  font-size:44px;
  margin-bottom:10px;
}

.boutique-subtitle{
  font-size:18px;
  color:var(--c-muted);
  margin-bottom:16px;
  max-width:62ch;
}

.luxe-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:10px 0 18px 0;
}

.luxe-badge{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(251,244,241,.85);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 6px 14px rgba(0,0,0,.06);
  font-weight:700;
}

.luxe-badge span{ font-size:18px; }

.boutique-cta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:10px 0 10px 0;
}

.boutique-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 18px;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.2px;
  border:2px solid transparent;
  transition: transform .08s ease, box-shadow .2s ease, background .2s ease;
  cursor:pointer;
  user-select:none;
}

.boutique-btn.primary{
  background:var(--c-primary);
  color:#fff;
  box-shadow:0 12px 22px rgba(168,59,59,.22);
}

.boutique-btn.primary:hover{
  background:var(--c-primary-dark);
}

.boutique-btn.secondary{
  background:#fff;
  color:var(--c-primary-dark);
  border-color:var(--c-primary);
  box-shadow:0 10px 18px rgba(0,0,0,.06);
}

.boutique-btn:hover{ transform: translateY(-1px); }

.boutique-btn.small{
  padding:12px 16px;
  font-weight:800;
}

.luxe-note{
  margin-top:10px;
  color:var(--c-muted);
}

/* Carte droite */
.luxe-hero-right{
  padding:6px;
}

.luxe-card{
  height:100%;
  padding:18px;
  border-radius:var(--radius);
  background:
    radial-gradient(circle at 80% 10%, rgba(168,59,59,.07), transparent 45%),
    radial-gradient(circle at 10% 70%, rgba(217,182,163,.22), transparent 60%),
    #fff;
}

.luxe-card-title{
  text-align:center;
  font-size:22px;
  margin-bottom:10px;
}

.luxe-card-text{
  text-align:center;
  color:var(--c-muted);
  margin-bottom:14px;
}

.luxe-checks{
  display:grid;
  gap:8px;
  margin:10px 0 16px 0;
  padding:12px 14px;
  border-radius:var(--radius-s);
  background:rgba(251,244,241,.85);
  border:1px solid rgba(0,0,0,.06);
}

.luxe-check{
  font-weight:700;
  color:#1f1a19;
}

.luxe-card-actions{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
  margin:6px 0 10px 0;
}

.luxe-card-mini{
  text-align:center;
  color:var(--c-muted);
  margin-top:10px;
}

/* =========================
   8) CATALOGUE (book)
   ========================= */
.catalogue-card{
  padding:16px;
}

.catalogue-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:10px;
}

.catalogue-head h3{
  margin:0;
  font-size:22px;
}

.catalogue-counter{
  font-weight:800;
  color:var(--c-muted);
}

.book-shell{
  position:relative;
  padding:14px 10px 12px 10px;
  border-radius:var(--radius);
  background:
    linear-gradient(180deg, rgba(251,244,241,.95), rgba(255,255,255,1));
  border:1px solid rgba(0,0,0,.06);
  box-shadow:var(--shadow-s);
}

.catalog-title{
  text-align:center;
  font-size:20px;
  margin:0 0 10px 0;
  color:var(--c-primary-dark);
}

.book{
  width:min(980px, 100%);
  margin:0 auto;
}

.book-page{
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 18px 28px rgba(0,0,0,.10);
}

.book-page img{
  width:100%;
  height:auto;
  display:block;
}

/* Flèches “dans le livre” */
.book-nav{
  position:absolute;
  top:50%;
  transform:translateY(-32%);
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(255,255,255,.92);
  box-shadow:0 12px 20px rgba(0,0,0,.10);
  cursor:pointer;
  font-size:28px;
  line-height:0;
  display:grid;
  place-items:center;
  color:var(--c-primary-dark);
  transition: transform .08s ease, background .2s ease;
}

.book-nav:hover{
  transform:translateY(-32%) scale(1.03);
  background:#fff;
}

.book-prev{ left:14px; }
.book-next{ right:14px; }

.catalogue-actions{
  margin-top:12px;
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}


.catalogue-tip{
  text-align:center;
  color:var(--c-muted);
  margin:10px 0 0 0;
}

/* =========================
   9) GAMMES (pastels plus visibles)
   ========================= */
.gammes-card{
  padding:16px;
}

.gammes-title{
  text-align:center;
  font-size:24px;
  margin-bottom:12px;
}

.gammes-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
}

.gamme-tile{
  border:1px solid rgba(0,0,0,.10);
  border-radius:14px;
  padding:14px 12px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 18px rgba(0,0,0,.06);
  transition: transform .08s ease, box-shadow .2s ease;
}

.gamme-tile:hover{
  transform: translateY(-1px);
  box-shadow:0 16px 26px rgba(0,0,0,.10);
}

/* Pastels plus accentués (toujours doux, mais plus visibles) */
.g-argan{ background:#FFE2D2; }      /* pêche */
.g-aloe{ background:#DFF5E6; }       /* vert clair */
.g-bave{ background:#EDEDED; }       /* gris clair */
.g-neem{ background:#DDEFE6; }       /* vert/gris */
.g-ane{ background:#EDE6FF; }        /* lilas */
.g-purifiante{ background:#DCEEFF; } /* bleu clair */
.g-antiage{ background:#FFDCE4; }    /* rose clair */
.g-bebe{ background:#FFF2B8; }       /* jaune doux */

.gammes-tip{
  text-align:center;
  color:var(--c-muted);
  margin:12px 0 0 0;
}

/* =========================
   10) SECTIONS “LUXE”
   ========================= */
.luxe-section{
  padding:16px;
}

.luxe-section-head{
  text-align:center;
  padding:8px 10px 14px 10px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(251,244,241,.90), rgba(255,255,255,1));
  border:1px solid rgba(0,0,0,.06);
}

.luxe-section-head h3{
  font-size:22px;
  margin-bottom:6px;
}

.luxe-section-head p{
  margin:0;
  color:var(--c-muted);
}

/* Media “premium” */
.luxe-media{
  margin-top:14px;
  border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.06);
  background:rgba(251,244,241,.65);
  padding:14px;
}

.luxe-media.compact{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}

.luxe-media-title{
  text-align:center;
  font-weight:900;
  color:var(--c-primary-dark);
  margin:0 0 10px 0;
}

.luxe-media img{
  border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.06);
  background:#fff;
  box-shadow:0 16px 26px rgba(0,0,0,.10);
  margin:0 auto;
  max-height:520px;
  object-fit:contain;
}

/* =========================
   11) POURQUOI (texte, moins de blanc)
   ========================= */
.luxe-why{
  padding:16px;
}

.why-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
}

.why-box{
  padding:14px 14px 12px 14px;
  border-radius:16px;
  background:rgba(251,244,241,.85);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 10px 18px rgba(0,0,0,.06);
}

.why-kicker{
  font-weight:900;
  color:var(--c-primary-dark);
  opacity:.95;
  margin-bottom:6px;
}

.why-title{
  font-weight:900;
  font-size:18px;
  color:#1f1a19;
  margin-bottom:4px;
}

.why-text{
  color:var(--c-muted);
  margin:0;
}

.why-split{
  margin-top:14px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:12px;
  align-items:stretch;
}

.why-list{
  padding:14px;
  border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.06);
  background:#fff;
}

.why-list ul{
  margin:0;
  padding-left:18px;
  color:#1f1a19;
}

.why-list li{
  margin:8px 0;
}

.why-cta{
  margin-top:12px;
}

.why-tip{
  padding:14px;
  border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.06);
  background:
    radial-gradient(circle at 80% 15%, rgba(168,59,59,.08), transparent 45%),
    rgba(251,244,241,.90);
  box-shadow:0 10px 18px rgba(0,0,0,.06);
}

.why-tip h4{
  margin:0 0 8px 0;
  color:var(--c-primary-dark);
  font-size:18px;
}

.why-tip-divider{
  height:1px;
  background:rgba(0,0,0,.10);
  margin:12px 0;
}

.why-tip-mini{
  margin:0;
  color:var(--c-muted);
}

/* =========================
   BOUTIQUE — Comparatif (version TEXTE)
   ========================= */

.compare-panel{
  grid-column: 1 / -1;
  padding: 16px;
  border-radius: var(--radius);
  border: 1px solid rgba(0,0,0,.06);
  background:
    radial-gradient(circle at 80% 10%, rgba(168,59,59,.06), transparent 45%),
    rgba(251,244,241,.55);
}

.compare-panel-title{
  text-align: center;
  margin: 0 0 6px 0;
  font-size: 20px;
}

.compare-panel-sub{
  text-align: center;
  color: var(--c-muted);
  margin: 0 0 14px 0;
}

.compare-cols{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: stretch;
}

.compare-col{
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 12px 22px rgba(0,0,0,.06);
  display: grid;
  gap: 10px;
}

.compare-col-title{
  margin: 0 0 2px 0;
  text-align: center;
  font-size: 18px;
  color: var(--c-primary-dark);
}

.compare-step{
  background: rgba(251,244,241,.85);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 14px;
  padding: 10px 12px;
}

.compare-step-title{
  font-weight: 900;
  color: #1f1a19;
  margin: 0 0 4px 0;
}

.compare-step-text{
  margin: 0;
  color: var(--c-muted);
}

.compare-price{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

.compare-price-label{
  color: var(--c-muted);
  font-weight: 800;
}

.compare-price-value{
  font-weight: 900;
  color: var(--c-primary-dark);
  font-size: 18px;
}

.compare-col.highlight{
  background:
    radial-gradient(circle at 80% 15%, rgba(168,59,59,.10), transparent 45%),
    #fff;
  border-color: rgba(168,59,59,.18);
}

.compare-footnote{
  margin: 0;
  color: var(--c-muted);
  text-align: center;
  padding-top: 6px;
}

/* Responsive */
@media (max-width: 980px){
  .compare-cols{
    grid-template-columns: 1fr;
  }
}


.compare-cta{
  grid-column: 1 / -1;
  display:flex;
  justify-content:center;
}

/* =========================
   13) COMMENT ÇA FONCTIONNE (plus clean)
   ========================= */
.how-card{
  padding:16px;
  text-align:center;
}

.how-title{
  font-size:22px;
  margin-bottom:10px;
}

.how-steps{
  display:grid;
  gap:8px;
  max-width:900px;
  margin:0 auto;
  padding-left:18px;
  text-align:left;
  color:#1f1a19;
}

.how-steps li{
  padding:10px 12px;
  border-radius:14px;
  background:rgba(251,244,241,.85);
  border:1px solid rgba(0,0,0,.06);
}

/* =========================
   14) RESPONSIVE
   ========================= */
@media (max-width: 980px){
  .luxe-hero-inner{
    grid-template-columns:1fr;
  }

  .boutique-title{
    font-size:38px;
  }

  .why-grid{
    grid-template-columns:1fr;
  }

  .why-split{
    grid-template-columns:1fr;
  }

  .gammes-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px){
  .text-content h1{ font-size:28px; }

  .boutique-title{ font-size:32px; }

  .book-nav{
    width:40px; height:40px;
  }

  .catalogue-card,
  .gammes-card,
  .luxe-section,
  .how-card,
  .luxe-hero{
    padding:14px;
  }

  .luxe-badge{
    width:100%;
    justify-content:center;
  }

  .boutique-btn{
    width:100%;
  }
}

/* Liste sans puces + style premium */
.luxe-list{
  list-style: none;
  padding-left: 0;
  margin: 12px 0 0;
}
.luxe-list li{
  position: relative;
  padding-left: 26px;
  margin: 10px 0;
  line-height: 1.55;
}
.luxe-list li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: 700;
  color: #a83b3b; /* ton rouge Bethy */
}
/* Assure que le footer reste visible et ne se “perd” pas */
html, body{ height: 100%; }
body{ margin: 0; }

/* Donne de l’air en bas si ton contenu est très “collé” */
.boutique-wrap{ padding-bottom: 40px; }

footer{
  background: #2f2f2f;
  color: #fff;
  text-align: center;
  padding: 16px 10px;
  font-size: 14px;
  line-height: 1.2;
}
footer p{ margin: 0; opacity: .95; }
.partner-contact{
  margin-top: 16px;
  padding: 16px 18px;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
  border: 1px solid rgba(0,0,0,.06);
}
.partner-contact h4{
  margin: 0 0 6px;
  color: #a83b3b;
}
.partner-contact p{
  margin: 6px 0 10px;
}
.partner-mail{
  display: inline-block;
  padding: 12px 16px;
  border-radius: 999px;
  background: #a83b3b;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}
.partner-mail:hover{ filter: brightness(.95); }
.partner-mini{
  margin-top: 10px;
  opacity: .85;
  font-size: 14px;
}
/* ===== FIX FOOTER VISIBILITÉ (à mettre TOUT EN BAS) ===== */
footer{
  background:#333;
  color:#fff;
  text-align:center;
  padding:14px 10px;
  margin-top:auto;
  width:100%;
}

footer p{
  margin:0;
  color:#fff !important; /* empêche les styles généraux de l’écraser */
  opacity:1;            /* si jamais un opacity global traîne */
}

.footer-links{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:16px;
  margin:0 0 10px;
}

.footer-links a{
  color:#fff;
  text-decoration:none;
  font-weight:600;
}

.footer-links a:hover{
  text-decoration:underline;
}

.consent-field{
  display:block;
  max-width:900px;
  margin:0 auto 10px;
  line-height:1.6;
  text-align:left;
}

.consent-field input{
  margin-right:10px;
}

.consent-field a{
  color:var(--c-primary-dark);
  text-decoration:underline;
  font-weight:700;
}

.form-helper{
  max-width:900px;
  margin:0 auto;
  font-size:.95rem;
  color:#6b5d5a;
  text-align:left;
}

.legal-shell{
  width:min(980px, calc(100% - 32px));
  margin:40px auto 56px;
}

.legal-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:20px;
  box-shadow:0 12px 30px rgba(0,0,0,.08);
  padding:32px 26px;
}

.legal-intro{
  margin-bottom:24px;
  padding-bottom:18px;
  border-bottom:1px solid rgba(0,0,0,.08);
}

.legal-kicker{
  display:inline-block;
  margin-bottom:10px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(168,59,59,.10);
  color:var(--c-primary-dark);
  font-weight:700;
  letter-spacing:.02em;
}

.legal-title{
  margin-bottom:10px;
  font-size:2rem;
  color:var(--c-primary-dark);
}

.legal-meta{
  color:#6b5d5a;
}

.legal-section{
  margin-top:24px;
}

.legal-section h2{
  margin-bottom:10px;
  font-size:1.3rem;
  color:var(--c-primary-dark);
}

.legal-section p{
  margin-bottom:12px;
  line-height:1.7;
}

.legal-list{
  margin:0;
  padding-left:20px;
  line-height:1.7;
}

.legal-list li{
  margin-bottom:8px;
}

.legal-placeholder{
  color:var(--c-primary-dark);
  font-weight:700;
}

@media(max-width:700px){
  .legal-card{
    padding:24px 18px;
    border-radius:18px;
  }

  .legal-title{
    font-size:1.7rem;
  }

  .footer-links{
    gap:10px 14px;
  }
}

/* =========================
   HOME PREMIUM
   ========================= */
.page-home{
  background:
    radial-gradient(circle at top, rgba(217,182,163,.18), transparent 30%),
    linear-gradient(180deg, #fbf4f1 0%, #f7efeb 100%);
  overflow-x:hidden;
}

.home-shell{
  max-width:1200px;
  margin:24px auto 60px;
  padding:0 14px;
}

.home-shell > section{
  margin:18px 0;
}

.luxe-hero-inner,
.home-proof-strip,
.home-offers-grid,
.home-process-grid,
.home-local-grid,
.home-faq-grid{
  align-items:stretch;
}

.luxe-hero-left,
.luxe-hero-right,
.home-proof-item,
.home-offer-card,
.home-local-card,
.home-map-card,
.home-faq-item,
.why-list,
.why-tip,
.luxe-section-head,
.home-hero-card{
  min-width:0;
  max-width:100%;
}

.home-hero-title,
.home-hero-copy,
.home-note,
.home-proof-item span,
.home-offer-card p,
.home-local-card p,
.home-map-card p,
.home-faq-item p,
.home-faq-item summary,
.why-tip p,
.why-tip-mini{
  overflow-wrap:anywhere;
}

.home-kicker{
  display:inline-block;
  margin-bottom:14px;
  padding:7px 13px;
  border-radius:999px;
  background:rgba(168,59,59,.10);
  color:var(--c-primary-dark);
  font-weight:800;
  letter-spacing:.03em;
}

.home-hero-title{
  font-size:52px;
  line-height:1.05;
  color:#2a2322;
  margin-bottom:14px;
}

.home-hero-copy{
  font-size:18px;
  color:var(--c-muted);
  max-width:60ch;
}

.home-note{
  max-width:62ch;
}

.home-hero-card{
  display:grid;
  gap:14px;
}

.home-hero-photo{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 20px 30px rgba(0,0,0,.10);
}

.home-hero-photo img{
  width:100%;
  height:100%;
  min-height:320px;
  object-fit:cover;
}

.home-proof-strip{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}

.home-proof-item{
  padding:18px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 12px 24px rgba(0,0,0,.06);
}

.home-proof-item strong{
  display:block;
  margin-bottom:8px;
  color:var(--c-primary-dark);
}

.home-proof-item span{
  color:var(--c-muted);
  line-height:1.55;
}

.home-offers-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}

.home-offer-card,
.home-local-card,
.home-map-card{
  padding:18px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 12px 24px rgba(0,0,0,.06);
}

.home-offer-card h4,
.home-local-card h4,
.home-map-card h4{
  font-size:22px;
  margin-bottom:10px;
}

.home-offer-card p,
.home-local-card p,
.home-map-card p{
  color:var(--c-muted);
}

.home-offer-tag{
  display:inline-block;
  margin:0 0 10px;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(217,182,163,.22);
  color:var(--c-primary-dark);
  font-weight:800;
  font-size:13px;
  letter-spacing:.03em;
  text-transform:uppercase;
}

.home-offer-price{
  margin-top:16px;
  font-size:20px;
  font-weight:900;
  color:var(--c-primary-dark) !important;
}

.home-section-actions{
  margin-top:18px;
  display:flex;
  justify-content:center;
}

.home-process-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:14px;
}

.home-process-steps{
  margin:0;
  padding-left:20px;
  line-height:1.7;
}

.home-process-steps li{
  margin-bottom:10px;
}

.home-gallery .carousel-container{
  margin-top:16px;
  max-width:none;
}

.home-gallery .carousel{
  gap:14px;
  padding:8px;
}

.home-gallery .carousel img{
  width:22%;
  min-width:220px;
  aspect-ratio:4 / 5;
  object-fit:cover;
  box-shadow:0 16px 28px rgba(0,0,0,.10);
}

.home-local-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.home-map-card{
  grid-column:1 / -1;
}

.home-contact-list{
  margin:0 0 18px;
  padding-left:18px;
  line-height:1.8;
}

.home-contact-list li{
  margin-bottom:4px;
}

.home-contact-list a{
  color:var(--c-primary-dark);
  font-weight:700;
}

.home-local-note{
  margin-bottom:18px;
}

.home-map-card iframe{
  border-radius:16px;
  box-shadow:0 12px 24px rgba(0,0,0,.08);
}

.home-faq-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.home-faq-item{
  padding:16px 18px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 12px 24px rgba(0,0,0,.06);
}

.home-faq-item summary{
  cursor:pointer;
  font-weight:800;
  color:#1f1a19;
  list-style:none;
}

.home-faq-item summary::-webkit-details-marker{
  display:none;
}

.home-faq-item p{
  margin:12px 0 0;
  color:var(--c-muted);
}

@media(max-width:980px){
  .home-proof-strip,
  .home-offers-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .home-process-grid,
  .home-local-grid,
  .home-faq-grid{
    grid-template-columns:1fr;
  }

  .home-hero-title{
    font-size:42px;
  }
}

@media(max-width:640px){
  .banner{
    padding:12px 14px;
  }

  .banner-content{
    display:grid;
    grid-template-columns:56px 1fr;
    align-items:center;
    column-gap:12px;
  }

  .logo-bethy{
    position:static;
    transform:none;
    width:56px;
  }

  .text-content{
    text-align:left;
  }

  .text-content h1{
    font-size:26px;
    margin:0;
  }

  .text-content p{
    margin-top:4px;
    font-size:14px;
  }

  .navbar{
    padding:10px 12px;
  }

  .navbar ul{
    width:100%;
    max-width:520px;
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
  }

  .navbar li:last-child{
    grid-column:1 / -1;
  }

  .navbar a{
    display:block;
    width:100%;
    text-align:center;
    padding:10px 12px;
    font-size:13px;
    line-height:1.25;
    background:rgba(255,255,255,.28);
  }

  .home-shell{
    margin:14px auto 34px;
    padding:0 10px;
  }

  .home-shell > section{
    margin:14px 0;
    overflow:hidden;
  }

  .luxe-hero.home-hero{
    padding:10px;
  }

  .luxe-hero-inner,
  .home-proof-strip,
  .home-offers-grid,
  .home-process-grid,
  .home-local-grid,
  .home-faq-grid{
    display:flex;
    flex-direction:column;
    gap:12px;
  }

  .luxe-hero-left,
  .luxe-card.home-hero-card{
    padding:14px;
  }

  .luxe-hero-left,
  .luxe-hero-right,
  .home-proof-item,
  .home-offer-card,
  .home-local-card,
  .home-map-card,
  .home-faq-item,
  .why-list,
  .why-tip{
    width:100%;
  }

  .home-kicker{
    display:inline-flex;
    width:auto;
    max-width:100%;
    margin-bottom:12px;
    padding:6px 10px;
    font-size:12px;
    line-height:1.35;
  }

  .home-hero-title{
    font-size:31px;
    line-height:1.08;
    margin-bottom:12px;
  }

  .home-hero-copy{
    font-size:16px;
    line-height:1.6;
    margin-bottom:14px;
  }

  .luxe-badges{
    flex-direction:column;
    gap:8px;
    margin:8px 0 14px;
  }

  .luxe-badge{
    width:100%;
    justify-content:flex-start;
    padding:10px 12px;
    font-size:14px;
  }

  .boutique-cta{
    flex-direction:column;
    gap:10px;
    margin:8px 0 8px;
  }

  .boutique-btn{
    width:100%;
    min-height:48px;
    padding:13px 16px;
  }

  .home-note{
    font-size:14px;
    line-height:1.6;
  }

  .luxe-hero-right{
    padding:0;
  }

  .home-map-card{
    grid-column:auto;
  }

  .home-hero-photo img{
    min-height:220px;
  }

  .home-proof-item,
  .home-offer-card,
  .home-local-card,
  .home-map-card,
  .home-faq-item,
  .why-list,
  .why-tip{
    padding:14px;
    border-radius:16px;
    box-shadow:0 10px 22px rgba(0,0,0,.06);
  }

  .luxe-section-head{
    padding:12px 12px 14px;
  }

  .luxe-section-head h3{
    font-size:20px;
  }

  .luxe-section-head p{
    font-size:14px;
    line-height:1.55;
  }

  .home-offer-card h4,
  .home-local-card h4,
  .home-map-card h4{
    font-size:20px;
    line-height:1.2;
  }

  .home-offer-price{
    margin-top:12px;
    font-size:18px;
  }

  .home-proof-strip,
  .home-offers-grid{
    grid-template-columns:1fr;
  }

  .home-process-grid,
  .home-local-grid,
  .home-faq-grid{
    gap:12px;
  }

  .home-process-steps{
    padding-left:18px;
    font-size:15px;
  }

  .home-gallery .carousel{
    gap:10px;
    padding:4px;
    overflow-x:auto;
  }

  .home-gallery .carousel img{
    min-width:148px;
    width:70%;
  }

  .home-contact-list{
    margin-bottom:14px;
    padding-left:16px;
    line-height:1.65;
  }

  .home-map-card iframe{
    height:260px;
  }

  .home-faq-item summary{
    padding-right:18px;
    line-height:1.4;
  }
}

@media(max-width:420px){
  .text-content h1{
    font-size:23px;
  }

  .text-content p{
    font-size:13px;
  }

  .navbar ul{
    grid-template-columns:1fr;
  }

  .navbar li:last-child{
    grid-column:auto;
  }

  .home-hero-title{
    font-size:28px;
  }

  .home-hero-copy,
  .home-note,
  .home-process-steps,
  .home-contact-list,
  .home-faq-item p{
    font-size:14px;
  }

  .home-kicker{
    font-size:11px;
  }

  .home-gallery .carousel img{
    min-width:132px;
  }
}


/* ---------------- END ---------------- */

/* ---------------- 2026 Luxury Theme Override ---------------- */
:root{
  --c-primary:#c7a05b;
  --c-primary-dark:#8c6930;
  --c-secondary:#101114;
  --c-bg-light:#0b0b0d;
  --c-bg-card:#f6efe4;
  --c-text:#181512;
  --c-ink:#181512;
  --c-muted:#6f6559;
  --c-soft:#ede1cb;
  --c-accent:#f3dfb3;
  --radius:18px;
  --shadow-s:0 12px 28px rgba(0,0,0,.18);
  --shadow-m:0 18px 36px rgba(0,0,0,.18);
  --shadow-l:0 24px 54px rgba(0,0,0,.22);
  --surface-marble:
    linear-gradient(145deg, rgba(248,243,234,.98), rgba(235,226,211,.96)),
    radial-gradient(circle at 12% 16%, rgba(255,255,255,.92), transparent 34%),
    repeating-linear-gradient(118deg, rgba(180,170,154,.14) 0 1px, rgba(255,255,255,0) 1px 24px);
  --surface-noir:
    linear-gradient(135deg, rgba(8,8,10,.98), rgba(20,20,24,.95));
}

body,
#finalibody{
  background:
    radial-gradient(circle at 16% 0%, rgba(199,160,91,.18), transparent 20%),
    radial-gradient(circle at 100% 8%, rgba(255,255,255,.06), transparent 16%),
    linear-gradient(135deg, #080809 0%, #111114 48%, #18181c 100%) !important;
  color:var(--c-ink);
}

.banner{
  background:
    linear-gradient(135deg, rgba(7,7,9,.98), rgba(18,18,21,.94)),
    linear-gradient(90deg, rgba(199,160,91,.24), transparent 38%, rgba(199,160,91,.12));
  border-bottom:1px solid rgba(199,160,91,.28);
  box-shadow:0 20px 48px rgba(0,0,0,.32);
}

.logo-bethy{
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.text-content h1,
.banner h1{
  color:#f8f2e9;
  letter-spacing:.02em;
}

.text-content p,
.banner p{
  color:#dcc089;
}

.navbar{
  background:rgba(10,10,12,.9);
  border-bottom:1px solid rgba(199,160,91,.22);
  box-shadow:0 16px 34px rgba(0,0,0,.24);
}

.navbar a{
  color:#f5ecdd;
  border:1px solid transparent;
}

.navbar a:hover,
.navbar a[aria-current="page"]{
  background:linear-gradient(135deg, #d7bb82 0%, #ba8e46 100%);
  color:#111113;
  border-color:rgba(255,255,255,.2);
  box-shadow:0 14px 28px rgba(0,0,0,.18);
}

footer{
  background:
    linear-gradient(135deg, rgba(7,7,9,.98), rgba(16,16,19,.96));
  color:#f5ecdd;
  border-top:1px solid rgba(199,160,91,.26);
  box-shadow:0 -16px 36px rgba(0,0,0,.24);
}

footer h2,
footer p,
.footer-links a{
  color:#f5ecdd;
}

.footer-links a{
  text-decoration:none;
  border-bottom:1px solid transparent;
}

.footer-links a:hover{
  color:#e6c98d;
  border-color:rgba(230,201,141,.7);
}

.services-header,
.people-count-card,
.person-service,
#contactInfo,
#recapServices,
.person-block,
.slot-wrapper,
.slot-col,
.catalogue-card,
.gammes-card,
.luxe-section,
.luxe-card,
.partner-contact,
.why-box,
.why-tip,
.home-proof-item,
.home-offer-card,
.home-local-card,
.home-map-card,
.home-faq-item{
  background:var(--surface-marble) !important;
  border:1px solid rgba(199,160,91,.24) !important;
  box-shadow:var(--shadow-m) !important;
}

.page-title,
#servicessss h2,
#gallery h2,
#location h2,
#horaires h2,
.services-header .page-title,
.services-header .service-note,
.partner-contact h4,
.person-block h3,
.total-price,
#weekLabel,
.slot-header,
.catalog-title,
.gammes-title,
.luxe-card-title,
.why-title,
.why-kicker{
  color:var(--c-primary-dark) !important;
}

.servicessss-note,
small,
.partner-mini,
.luxe-card-mini,
.catalogue-tip,
.gammes-tip,
.form-helper{
  color:var(--c-muted) !important;
}

.input-style,
.phone-input,
textarea,
select,
input[type="text"],
input[type="tel"],
input[type="email"]{
  background:rgba(255,252,246,.95);
  border:1px solid rgba(199,160,91,.34) !important;
  color:var(--c-ink);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 10px 22px rgba(0,0,0,.06);
}

.input-style:focus,
textarea:focus,
select:focus,
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="email"]:focus{
  outline:none;
  border-color:rgba(199,160,91,.72) !important;
  box-shadow:0 0 0 4px rgba(199,160,91,.18), 0 12px 24px rgba(0,0,0,.08);
}

button,
.custom-file-upload,
#contactInfo button,
#proposeAppointment,
.boutique-btn.primary,
.nav-btn{
  background:linear-gradient(135deg, #e5cb95 0%, #b98d48 100%) !important;
  color:#141416 !important;
  border:1px solid rgba(112,82,31,.28);
  box-shadow:0 14px 28px rgba(0,0,0,.16);
}

button:hover,
.custom-file-upload:hover,
#contactInfo button:hover,
#proposeAppointment:hover,
.boutique-btn.primary:hover,
.nav-btn:hover{
  background:linear-gradient(135deg, #f0d9a8 0%, #c59a53 100%) !important;
}

.buttonn{
  background:linear-gradient(135deg, #131316 0%, #26262c 100%) !important;
  border:1px solid rgba(199,160,91,.36);
  box-shadow:0 18px 34px rgba(0,0,0,.28);
}

.buttonn:hover{
  background:linear-gradient(135deg, #1b1b1f 0%, #2d2d33 100%) !important;
}

.buttonn__circle{
  background:linear-gradient(135deg, #ebd4a2 0%, #c1954e 100%) !important;
  color:#141416 !important;
}

.buttonn__icon--copy{
  color:#141416 !important;
}

.slot-nav button{
  color:var(--c-primary-dark) !important;
}

.slot-btn{
  background:rgba(255,252,246,.94);
  border-color:rgba(199,160,91,.24);
  color:var(--c-primary-dark);
}

.slot-btn.selected{
  background:linear-gradient(135deg, #e4c88e 0%, #b78b46 100%) !important;
  color:#141416 !important;
  border-color:rgba(112,82,31,.28) !important;
}

.catalogue-card,
.gammes-card,
.luxe-section{
  color:var(--c-ink);
}

#finali{
  background:
    linear-gradient(135deg, rgba(7,7,9,.98), rgba(18,18,22,.96)) !important;
  border-bottom:1px solid rgba(199,160,91,.24);
  box-shadow:0 20px 40px rgba(0,0,0,.26);
}

#finalih1,
#finali h3{
  color:#f4e7d0 !important;
}

#recapServices > h2,
#confirmForm .section-center h3,
#contactInfo h3,
#contactInfo label,
.slot-help,
.consent-field{
  color:#ead2a0 !important;
}

.consent-field a{
  color:#f3dfb3 !important;
}

#recapServices > h2{
  background:var(--surface-marble);
  border:1px solid rgba(199,160,91,.22);
  border-radius:18px;
  padding:14px 18px;
  box-shadow:var(--shadow-m);
}

/* ----- Finaliser 2026 full restyle ----- */
#finali.final-header{
  position:relative;
  padding:22px 16px 26px !important;
}

.final-header-inner{
  width:min(1200px, calc(100% - 12px));
  margin:0 auto;
  min-height:96px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}

#finali .buttonn--header{
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  width:auto;
  min-width:190px;
  height:58px;
  padding:10px 18px 10px 12px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  overflow:visible;
}

#finali .buttonn--header:hover{
  transform:translateY(-50%) translateY(-1px);
}

#finali .buttonn--header .buttonn__text{
  display:none;
}

#finali .buttonn--header .buttonn__circle{
  width:36px;
  height:36px;
  flex:0 0 auto;
}

#finali .buttonn--header::after{
  content:"Retour accueil";
  font-size:15px;
  font-weight:700;
  letter-spacing:.02em;
  color:#f3dfb3;
}

.final-header-copy{
  display:grid;
  justify-items:center;
  gap:6px;
}

#finalih1{
  margin:0;
  font-size:2.3rem;
}

#finali h3{
  margin:0;
  font-size:1rem;
  text-decoration:none;
}

#confirmForm{
  width:min(1220px, calc(100% - 32px));
  margin:0 auto 56px;
}

.final-section{
  width:100%;
  max-width:none;
  margin:26px auto;
  padding:0;
}

.final-slots-section h3,
.final-upload-shell h3,
.final-consent-section h3{
  margin-bottom:14px;
  text-align:center;
}

#recapServices{
  width:min(1220px, calc(100% - 32px));
  margin:34px auto 24px;
  padding:24px;
}

.person-block{
  background:
    linear-gradient(145deg, rgba(248,243,234,.98), rgba(231,222,208,.96)),
    radial-gradient(circle at 14% 16%, rgba(255,255,255,.9), transparent 34%),
    repeating-linear-gradient(118deg, rgba(184,173,156,.12) 0 1px, rgba(255,255,255,0) 1px 22px) !important;
  border:1px solid rgba(199,160,91,.22);
  border-left:0 !important;
  box-shadow:0 20px 40px rgba(0,0,0,.16) !important;
}

.person-block h3,
.person-block li,
.total-price{
  color:#1b1714 !important;
}

.person-block ul{
  list-style:none;
  margin:12px 0 0;
  padding:0;
  display:grid;
  gap:8px;
}

.person-block li{
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(199,160,91,.12);
}

.slot-wrapper{
  padding:24px 22px !important;
}

.slot-nav{
  margin-bottom:18px;
}

.slot-selection-count{
  width:fit-content;
  margin:0 auto 18px !important;
  padding:10px 16px;
  border-radius:999px;
  background:rgba(199,160,91,.14);
  border:1px solid rgba(199,160,91,.22);
  color:#3b3025 !important;
  font-weight:800;
  font-size:.95rem;
  letter-spacing:.01em;
  text-align:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.64);
}

.slot-nav button{
  width:48px;
  height:48px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(145deg, rgba(248,243,234,.98), rgba(231,222,208,.96));
  border:1px solid rgba(199,160,91,.24);
  box-shadow:0 12px 26px rgba(0,0,0,.12);
}

#weekLabel{
  color:#2b241d !important;
}

.slot-col{
  background:
    linear-gradient(145deg, rgba(248,243,234,.98), rgba(231,222,208,.96)),
    radial-gradient(circle at 14% 16%, rgba(255,255,255,.9), transparent 34%),
    repeating-linear-gradient(118deg, rgba(184,173,156,.12) 0 1px, rgba(255,255,255,0) 1px 22px) !important;
  border:1px solid rgba(199,160,91,.24) !important;
  box-shadow:0 20px 36px rgba(0,0,0,.14) !important;
}

.slot-header{
  color:#2b241d !important;
  font-weight:800;
}

.slot-btn{
  position:relative;
  background:linear-gradient(145deg, rgba(216,174,106,.92), rgba(198,149,73,.94)) !important;
  color:#1a1714 !important;
  border:1px solid rgba(151,111,49,.24) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 10px 20px rgba(0,0,0,.1) !important;
}

.slot-btn:hover{
  filter:brightness(1.04);
}

.slot-btn.selected{
  background:linear-gradient(145deg, rgba(13,13,16,.98), rgba(34,34,39,.96)) !important;
  color:#f3dfb3 !important;
  border:1px solid rgba(199,160,91,.5) !important;
  box-shadow:0 0 0 3px rgba(199,160,91,.22), 0 16px 30px rgba(0,0,0,.26) !important;
  transform:translateY(-1px);
}

.slot-btn.selected::after{
  content:"✓";
  position:absolute;
  top:6px;
  right:7px;
  font-size:11px;
  line-height:1;
  color:#f3dfb3;
}

.slot-help{
  margin-top:14px;
  color:#7a6d5d !important;
  text-align:center;
}

#contactInfo{
  width:100%;
  margin:0 auto !important;
  padding:34px 30px !important;
  gap:14px !important;
}

#contactInfo h3{
  margin-bottom:10px;
  text-align:center;
  font-size:2rem;
  color:#2a221b !important;
}

#recapServices > h2,
.final-slots-section > h3,
.final-upload-shell h3{
  color:#2a221b !important;
}

#recapServices > h2{
  width:fit-content;
  margin:0 auto 12px !important;
  background:linear-gradient(145deg, rgba(244,229,193,.92), rgba(226,203,150,.8));
  color:#2a221b !important;
  box-shadow:0 16px 28px rgba(0,0,0,.1), inset 0 1px 0 rgba(255,255,255,.65);
}

#contactInfo label{
  display:block;
  margin:8px 0 6px;
  color:#261f18 !important;
  font-weight:700;
  font-size:.98rem;
  letter-spacing:.01em;
}

.input-style,
.phone-input,
#contactInfo textarea,
#contactInfo input[type="text"],
#contactInfo input[type="tel"]{
  min-height:56px;
  padding:15px 18px !important;
  border-radius:18px !important;
  border:1px solid rgba(199,160,91,.28) !important;
  background:
    linear-gradient(145deg, rgba(252,248,241,.98), rgba(239,230,216,.94)),
    radial-gradient(circle at 12% 16%, rgba(255,255,255,.94), transparent 38%);
  color:#1a1714 !important;
  font-size:16px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88), 0 12px 24px rgba(0,0,0,.06) !important;
}

.input-style::placeholder,
#contactInfo textarea::placeholder,
#contactInfo input[type="text"]::placeholder,
#contactInfo input[type="tel"]::placeholder{
  color:#7a6e60 !important;
  opacity:1;
}

#contactInfo textarea{
  min-height:124px;
  resize:vertical;
}

.visit-type-toggle{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:center;
  margin:8px 0 12px;
}

.visit-type-option{
  display:inline-flex !important;
  align-items:center;
  gap:10px;
  margin:0 !important;
  padding:12px 18px;
  border-radius:999px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(199,160,91,.2);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
}

.visit-type-option:has(input:checked){
  background:linear-gradient(145deg, #121215 0%, #24242a 100%);
  border-color:rgba(199,160,91,.4);
  box-shadow:0 14px 28px rgba(0,0,0,.16);
  color:#f4dfb3 !important;
}

.visit-type-option input{
  accent-color:#0f1013;
  transform:scale(1.15);
}

.final-upload-shell{
  padding:0;
}

.upload-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}

.upload-card{
  padding:28px 24px;
  border-radius:22px;
  background:
    linear-gradient(145deg, rgba(248,243,234,.98), rgba(231,222,208,.96)),
    radial-gradient(circle at 14% 16%, rgba(255,255,255,.9), transparent 34%),
    repeating-linear-gradient(118deg, rgba(184,173,156,.12) 0 1px, rgba(255,255,255,0) 1px 22px);
  border:1px solid rgba(199,160,91,.24);
  box-shadow:0 20px 38px rgba(0,0,0,.14);
  text-align:left;
}

.upload-card h3{
  margin:0 0 8px;
  color:#231d18 !important;
}

.upload-card p{
  margin:0 0 16px;
  color:#665b50 !important;
}

.upload-input{
  width:100%;
  padding:16px 18px;
  border-radius:18px;
  border:1px dashed rgba(199,160,91,.34);
  background:rgba(255,255,255,.42);
  font-size:15px;
  color:#3a322c;
}

.upload-input::file-selector-button{
  margin-right:12px;
  padding:12px 18px;
  border:none;
  border-radius:999px;
  background:linear-gradient(145deg, #121215 0%, #25252b 100%);
  color:#f4dfb3;
  font-weight:700;
  cursor:pointer;
  box-shadow:0 12px 24px rgba(0,0,0,.16);
}

.upload-meta{
  margin:14px 0 0 !important;
  color:#6b5f52 !important;
  font-size:.92rem;
  font-weight:700;
}

.final-consent-section{
  max-width:980px;
}

.consent-field{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:18px 20px;
  border-radius:18px;
  background:
    linear-gradient(145deg, rgba(248,243,234,.98), rgba(231,222,208,.96)),
    radial-gradient(circle at 14% 16%, rgba(255,255,255,.9), transparent 34%),
    repeating-linear-gradient(118deg, rgba(184,173,156,.12) 0 1px, rgba(255,255,255,0) 1px 22px);
  border:1px solid rgba(199,160,91,.22);
  box-shadow:0 18px 32px rgba(0,0,0,.12);
  color:#2a221b !important;
}

.consent-field input{
  accent-color:#111215;
  margin-top:3px;
}

.form-helper{
  margin-top:10px !important;
  color:#d7cab5 !important;
  text-align:center;
}

.final-submit{
  display:block;
  min-width:280px;
  margin:26px auto 0 !important;
  padding:15px 26px !important;
  border-radius:999px !important;
  background:linear-gradient(145deg, #121215 0%, #25252b 100%) !important;
  color:#f4dfb3 !important;
}

.final-submit:hover{
  filter:brightness(1.04);
}

@media(max-width:900px){
  .final-header-inner{
    min-height:auto;
    padding-top:74px;
  }

  #finali .buttonn--header{
    top:0;
    left:50%;
    transform:translate(-50%, 0);
  }

  #finali .buttonn--header:hover{
    transform:translate(-50%, -1px);
  }

  #finalih1{
    font-size:1.9rem;
  }

  .upload-grid{
    grid-template-columns:1fr;
  }

  #contactInfo{
    padding:22px 18px !important;
  }
}

@media(max-width:700px){
  #confirmForm,
  #recapServices{
    width:min(100%, calc(100% - 20px));
  }

  .slot-wrapper{
    padding:18px 14px !important;
  }

  .visit-type-toggle{
    flex-direction:column;
  }

  .visit-type-option{
    justify-content:center;
    text-align:center;
  }

  .upload-card{
    padding:20px 16px;
  }

  .slot-selection-count{
    width:100%;
    margin-bottom:14px !important;
    font-size:.88rem;
  }
}
